<?php

function index() {
    global $contenido;

    $dbc = conectarBD();
    $resultado = pg_query($dbc, "SELECT * FROM producto;");
    if (!$resultado) {

        $contenido["error"] = "No se ha podido contactar a la base de datos.";
    } else {
        $productos = pg_fetch_all($resultado);
        if (!$productos)
            $contenido["info"] = "No hay producto en la base de datos.";
        else
            $contenido["productos"] = $productos;
    }
    pg_close($dbc);
}

function view() {
    global $contenido;

    $codigo = @$_GET["codigo"];
    if (!$codigo) {
        $contenido["error"] = "Debe especificar el codigo del producto.";
    } else {
        $dbc = conectarBD();
        pg_prepare($dbc, "delete_query", "SELECT * FROM producto WHERE codigo = $1;");
        $resultado = pg_execute($dbc, "delete_query", array($codigo));
        $resultadoArray = pg_fetch_all($resultado);
        pg_close($dbc);
        if (!$resultado || !$resultadoArray) {
            $contenido["error"] = "No se ha encontrado el producto señalado.";
        } else {
            $contenido["producto"] = $resultadoArray[0];
        }
    }
}

function create() {
    Response::$view = "form";
}

function edit() {
    global $contenido;
    view();
    Response::$view = "form";
}

function persist() {
    global $contenido;
    $_GET["codigo"] = $_POST["codigo"];
    view();

    $dbc = conectarBD();
    if (!array_key_exists("producto", $contenido)) {
        $consulta = "INSERT INTO producto VALUES(".$_POST["codigo"].",".$_POST["modelo"].",".$_POST["descripcion"].",".$_POST["tipo"].",".$_POST["precio"].",".$_POST["rut"].");";
        pg_prepare($dbc, "persist_query", "INSERT INTO producto VALUES($1,$2,$3,$4,$5,$6)");
    } else {
        $consulta = "UPDATE producto SET modelo=".$_POST["modelo"].",descripcion=".$_POST["descripcion"].",tipo=".$_POST["tipo"].",precio=".$_POST["precio"].",rut=".$_POST["rut"]." WHERE codigo=".$_POST["codigo"].";";
        pg_prepare($dbc, "persist_query", "UPDATE producto SET modelo=$2,descripcion=$3,tipo=$4,precio=$5,rut=$6 WHERE codigo=$1");
    }
    $resultado = pg_execute($dbc, "persist_query", $_POST);
    pg_close($dbc);
    if (!$resultado || $resultado == 0) {
        $contenido["error"] = "No se ha podido guardar el producto.";
    } else {
        $contenido = array();
        $contenido["exito"] = "Los datos del producto se han guardado exitosamente.";
        $log = guardarEnLog($consulta);
    }

    index();
    Response::$view = "index";
}

function delete() {
    global $contenido;

    $codigo = @$_POST["codigo"];
    if (!$codigo) {
        $contenido["error"] = "Debe especificar el codigo del producto.";
    } else {
        $dbc = conectarBD();
        $consulta = "DELETE FROM producto WHERE codigo = ".$_POST["codigo"].";";
        pg_prepare($dbc, "delete_query", "DELETE FROM producto WHERE codigo = $1");
        $resultado = pg_execute($dbc, "delete_query", array($codigo));
        pg_close($dbc);
        if (!$resultado || pg_affected_rows($resultado) == 0) {
            $contenido["error"] = "No se ha encontrado un producto con el codigo indicado.";
        } else {
            $contenido["alerta"] = "Se ha eliminado correctamente al producto especificado.";
            $log = guardarEnLog($consulta);
        }
    }

    index();
    Response::$view = "index";
}

?>
